package com.sys.system.domain;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.sys.common.annotation.Excel;
import com.sys.common.annotation.Excel.ColumnType;
import com.sys.common.core.domain.BaseParam;
import lombok.Data;
import lombok.experimental.Accessors;

import java.io.Serial;
import java.io.Serializable;
import java.util.Date;

/**
 * 系统访问记录表 sys_logininfor
 *
 * @author LGY
 */
@Data
@Accessors(chain = true)
@TableName("sys_logininfor")
public class SysLoginInfo extends BaseParam implements Serializable {

    @Serial
    private static final long serialVersionUID = 2560981312144799315L;
    /**
     * ID
     */
    @Excel(name = "序号", cellType = ColumnType.NUMERIC)
    @TableId(value = "id", type = IdType.ASSIGN_ID)
    private String id;

    /**
     * 用户账号
     */
    @Excel(name = "用户账号")
    @TableField(value = "user_name")
    private String userName;

    /**
     * 登录状态 0成功 1失败
     */
    @Excel(name = "登录状态", readConverterExp = "0=成功,1=失败")
    @TableField(value = "status")
    private String status;

    /**
     * 登录IP地址
     */
    @Excel(name = "登录地址")
    @TableField(value = "ipaddr")
    private String ipaddr;

    /**
     * 登录地点
     */
    @Excel(name = "登录地点")
    @TableField(value = "login_location")
    private String loginLocation;

    /**
     * 浏览器类型
     */
    @Excel(name = "浏览器")
    @TableField(value = "browser")
    private String browser;

    /**
     * 操作系统
     */
    @Excel(name = "操作系统")
    @TableField(value = "os")
    private String os;

    @Excel(name = "类型", readConverterExp = "-1=未知,0=登录,1=退出,2=注册")
    @TableField(value = "type")
    private Integer type;

    /**
     * 提示消息
     */
    @Excel(name = "提示消息")
    @TableField(value = "msg")
    private String msg;

    /**
     * 访问时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "访问时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    @TableField(value = "login_time")
    private Date loginTime;
}
